草庐IT

json - 从 url 读取 json

全部标签

Ruby:如何确定正在读取的文件是二进制文件还是文本文件

我正在用Ruby编写一个程序,它将在目录中的文本文件中搜索字符串-类似于Grep。我不希望它尝试在二进制文件中搜索,但我无法在Ruby中找到确定文件是二进制文件还是文本文件的方法。该程序需要同时在Windows和Linux上运行。如果有人能指出我正确的方向,那就太好了。谢谢,黄原素 最佳答案 libmagic是一个检测文件类型的库。对于这个解决方案,我假设所有以text/开头的mimetype都代表文本文件。其他的都是二进制文件。这个假设并不适用于所有mime类型(例如application/x-latex、application/

ruby-on-rails - 在 Ruby on Rails 中增量构建任意 URL

我有一个字符串形式的URL。向其中添加一些参数最简洁的方法是什么?例如base='http://example.com'uri1=some_magical_method(base,:p1=>'v1')#=>http://example.com/?p1=v1uri2=some_magical_method(uri1,:p2=>'v2')#=>http://example.com/?p1=v1&p2=v2uri3=some_magical_method(uri2,:p3=>nil)#=>http://example.com/?p1=v1&p2=v21)在Ruby中?2)在Rails中?

ruby-on-rails - gem install json 失败,重新定义了 struct timezone/timespec

我在Windows上使用带有DevKit的Ruby1.9.3(在Win764位上都是32位)。现在我尝试安装rails,但从bundle中得到一个错误。如果我尝试运行(包在提示什么)geminstalljson我收到以下错误消息:D:\RubyTest>geminstalljsonTemporarilyenhancingPATHtoincludeDevKit...Buildingnativeextensions.Thiscouldtakeawhile...ERROR:Errorinstallingjson:ERROR:Failedtobuildgemnativeextension.D:

ruby - 在 Ruby 中,如何从散列输出 json 并给它换行和制表符

我正在尝试格式化{"key"=>"value"}以将其转换为:{"key":"value"}用于写入json文件。现在我正在做:hash={"key"=>"value"}putshash.to_json.gsub('{','{\n\t')开始。这输出{\n\t"key":"value"}为什么我不能换行? 最佳答案 为漂亮的东西欢呼,为避免正则表达式欢呼!使用内置的JSON.pretty_generate方法require'json'putsJSON.pretty_generatehash,options耶!选项如下:indent:

ruby - nil.to_json 无法解析回 nil?

此代码段抛出异常:x=niljsoned=x.to_jsonputs'x.to_json='+jsoned.inspectputs'back='+JSON.parse(jsoned).inspectC:/ruby/lib/ruby/1.9.1/json/common.rb:146:in`parse':706:unexpectedtokenat'null'(JSON::ParserError)x.to_json="null"fromC:/ruby/lib/ruby/1.9.1/json/common.rb:146:in`parse'fromC:/dev/prototyping/appox

ruby-on-rails - Ruby - 批量读取文件

我正在读取一个大小为10mb且包含一些ID的文件。我将它们读入ruby列表。我担心将来可能会导致内存问题,因为文件中的id数量可能会增加。有没有一种批量读取大文件的有效方法?谢谢 最佳答案 与LazyEnumerators和each_slice,您可以两全其美。中间切线不用担心,可以批量迭代多行。batch_size可以自由选择。header_lines=1batch_size=2000File.open("big_file")do|file|file.lazy.drop(header_lines).each_slice(batch

ruby-on-rails - 在 ruby​​ on rails 中使用 facebook graph api 时从 url 获取一个 json 对象

如何在我的ruby​​onrails代码中通过URL获取JSON对象:url="https://graph.facebook.com/me/friends?access_token=XXX"我无法获得有关JSON+RubyonRails的良好教程。谁能帮帮我,谢谢。 最佳答案 require'open-uri'require'json'json_object=JSON.parse(open("https://graph.facebook.com/me/friends?access_token=XXX").read)这是最简单的方法,

ruby - 在 ruby​​ 中对 JSON 哈希数组进行排序

所以我有一个哈希数组:[{"id":"30","name":"Dave"},{"id":"57","name":"Mike"},{"id":"9","name":"Kevin"},...{"id":"1","name":"Steve"}]我想按id属性对其进行排序,使其看起来像这样:[{"id":"1","name":"Steve"},{"id":"2","name":"Walter"},...{"id":"60","name":"Chester"}]我假设我使用的是sort_by方法,但我不确定该怎么做。 最佳答案 这应该有效:a

ruby - 如何在 Rails 4 中访问 *_path 和 *_url 助手

我正在阅读Rails:Checkoutputofpathhelperfromconsole并且没有一个解决方案对我有用,大概是因为它们都适用于Rails2/3。在Rails4/5中,如何从Rails控制台访问*_path和*_url助手? 最佳答案 运行Rails4,我得到它们:app.root_path=>"/"app.users_url=>"http://www.example.com/users" 关于ruby-如何在Rails4中访问*_path和*_url助手,我们在Stack

Ruby - 如何从文件中读取前 n 行到数组中

出于某种原因,我找不到任何提及如何执行此操作的教程...那么,如何从文件中读取前n行?我想出了:whileFile.open('file.txt')andcount但它不起作用,而且对我来说也不是很好。出于好奇,我试过类似的东西:File.open('file.txt').10.timesdo|f|但这也没有真正起作用。那么,有没有一种简单的方法可以只读取前n行而不必加载整个文件?非常感谢! 最佳答案 这是一个单行解决方案:lines=File.foreach('file.txt').first(10)我担心它可能不会及时关闭文件(